3、Publish Subscribe
http://previous.rabbitmq.com/v3_5_7/tutorials/tutorial-three-php.html
临时队列
当我们将队列名称作为空字符串提供时,我们使用生成的名称创建一个非持久队列:
list($queue_name, ,) = $channel->queue_declare("");
绑定
我们已经创建了一个扇出交换和一个队列。现在我们需要告诉交换机将消息发送到我们的队列。交换和队列之间的关系称为绑定。
$ channel-> queue_bind($ queue_name,'logs');
emit_log.php脚本的代码 :
<?php
require_once __DIR__ . '/vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPStreamConnection;
use PhpAmqpLib\Message\AMQPMessage;
$connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
$channel = $connection->channel();
//第二个参数为类型 有direct, topic, headers and fanout类型。 fanout交换非常简单。正如您可能从名称中猜到的那样,它只是将收到的所有消息广播到它知道的所有队列中。而这正是我们记录器所需要的。
$channel->exchange_declare('logs', 'fanout', false, false, false);
$data = implode(' ', array_slice($argv, 1));
if (empty($data)) {
$data = "info: Hello World!";
}
$msg = new AMQPMessage($data);
//路由键是basic_publish的第二个参数,消息被路由到具有routing_key指定的名称的队列(如果存在)
$channel->basic_publish($msg, 'logs');
echo ' [x] Sent ', $data, "\n";
$channel->close();
$connection->close();
?>
receive_logs.php的代码:
<?php
require_once __DIR__ . '/vendor/autoload.php';
use PhpAmqpLib\Connection\AMQPStreamConnection;
$connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');
$channel = $connection->channel();
$channel->exchange_declare('logs', 'fanout', false, false, false);
/**
* 当我们将队列名称作为空字符串提供时,我们使用生成的名称创建一个非持久队列
* 方法返回时,$ queue_name变量包含RabbitMQ生成的随机队列名称。例如,它可能看起来像amq.gen-JzTY20BRgKO-HjmUJj0wLg。
* 当声明它的连接关闭时,队列将被删除,因为它被声明为独占。
*/
list($queue_name, ,) = $channel->queue_declare("", false, false, true, false);
//我们已经创建了一个扇出交换和一个队列。现在我们需要告诉交换机将消息发送到我们的队列。交换和队列之间的关系称为绑定。
$channel->queue_bind($queue_name, 'logs');
echo " [*] Waiting for logs. To exit press CTRL+C\n";
$callback = function ($msg) {
echo ' [x] ', $msg->body, "\n";
};
$channel->basic_consume($queue_name, '', false, true, false, false, $callback);
while (count($channel->callbacks)) {
$channel->wait();
}
$channel->close();
$connection->close();
?>